

|     | 앞 |    |
|-----|---|----|
| 2조  |   | 4조 |
| 6조  |   | 8조 |
| 10조 |   |    |
|     |   |    |
|     |   |    |
|     |   |    |



|    | 앞 |     |  |
|----|---|-----|--|
| 1조 |   | 3조  |  |
| 5조 |   | 7조  |  |
| 9조 |   | 11조 |  |
|    |   |     |  |
|    |   |     |  |
|    |   |     |  |

# 주차별 실험 계획



| 주차    | 날짜          | 실험내용                                           |
|-------|-------------|------------------------------------------------|
| 1     | 09.02       | 분반편성 및 Overview                                |
| 2     | 09.08       | 개발 환경 구축 및 개발 장비 교육                            |
| 3     | 09.15       | 디버깅 툴(J-Link) 및<br>레지스터와 주소 제어를 통한 임베디드 펌웨어 개발 |
| 4     | 09.22       | 휴강 (추석)                                        |
| 5     | 09.29       | 스캐터 로딩 파일 및 플래시 메모리 이해                         |
| 6     | 10.06       | Polling 방식을 이용한 UART 통신 및 Clock control        |
| 7     | 10.13       | Interrupt 방식을 활용한 GPIO 제어 및 UART 통신            |
| 8     | 10.20       | 휴강 (중간고사 없음)                                   |
| 9     | 10.27       | Bluetooth 및 납땜                                 |
| 10    | 11.03       | TFT-LCD 제어 및 ADC 구현                            |
| 11    | 11.10       | Timer 및 PWM 구현                                 |
| 12    | 11.17       | DMA 구현                                         |
| 13~   | 11.24~12.24 | 텀 프로젝트 진행 (최종 검사일은 미정)                         |
| 15~16 | 12.08~12.19 | 기말고사 (시험일은 미정)                                 |

### 차후에 변경 가능



#### 예비 발표 방법 변경

- 발표 영상을 녹화하여 조교 이메일 (chrismail@naver.com) 로 제출
- 모든 학생은 조교가 PLATO에 업로드한 동영상 각자 시청 (시청 체크하여 성적에 반영)

#### 제출 기한

| 10월 6일 | 10월 13일 | 10월 27일 | 11월 3일 | 11월 10일 | 11월 17일 |
|--------|---------|---------|--------|---------|---------|
| 7, 8   | 1, 10   | 11, 6   | 5, 2   | 9, 4    | 3       |





September 21, 2020

조교 김준명 chrismail@naver.com

## 임베디드 시스템 설계 및 실험 수요일 분반

5주차 USART



### **Contents**

5주차 실험 내용

## 실험 목적



- 라이브러리를 활용하여 코드 작성
- Clock Tree 의 이해 및 사용자 Clock 설정
- 오실로스코프를 이용한 clock 확인
- UART 통신의 원리를 배우고 실제 설정 방법 파악

# 라이브러리 활용



| 직접 주소로 접근   | (*(volatile unsigned int *) $0x40021018$ ) &= $\sim 0x20$ ;<br>(*(volatile unsigned int *) $0x40021018$ )  = $0x20$ ;<br>(*(volatile unsigned int *) $0x40011000$ ) &= $\sim 0x000000F00$ ;<br>(*(volatile unsigned int *) $0x40011000$ )  = $0x000000400$ ; |  |  |  |  |  |
|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| 정의된 주소 값 사용 | RCC->APB2ENR &= ~(RCC_APB2ENR_IOPDEN);<br>RCC->APB2ENR  = RCC_APB2ENR_IOPDEN;<br>GPIOD->CRL &= ~(GPIO_CRL_CNF2   GPIO_CRL_MODE2);<br>GPIOD->CRL  = GPIO_CRL_MODE2_0;                                                                                         |  |  |  |  |  |

## 라이브러리 활용





정의된 변수명 또는 함수명 : stm32f10x.h 또는 다른 라이브러리 파일에서 찾기

코드에서 이름을 어느 정도 입력 후 ctrl+spacebar 또는 ctrl+alt+spacebar 를 누르면 정의된 이름들로 바로 변경되기도 함



### **HSI(High-speed internal) Clock**

 HSI Clock은 내부의 RC 오실레이터 주파 수를 클럭 소스로 사용.
 (현재 보드는 8 MHz, Datasheet 참고)

#### **HSE(High-speed external) Clock**

 HSE Clock은 외부의 크리스탈 또는 오 실레이터 주파수를 클럭 소스로 사용.
 (25 MHz, Schematic + Reference 참고)

#### PLL(Phase-Locked Loop)

- 신호의 위상고정 회로(클럭의 delay등의 이유로 틀진 신호를 동기화 하기위해 신호의 고정점을 맞추는 용도)
- HSI 또는 HSE 신호를 PLL 회로 내에서 배수계산을 이용해 원하는 SYSCLK으로 만들어냄



- 1. PLLCLK = HSI RC / 2 \* PLLMUL
- 2. PLLCLK = **HSE** OSC / PREDIV1 \* PLLMUL
- 3. PLLCLK = **HSE** OSC / PREDIV2 \* PLL2MUL / PREDIV1 \* PLLMUL



#### **Clock Tree**



- 만들어진 시스템 클릭 SYSCLK(최대 72MHz)은 AHB, APB1, APB2에 전달되어 사용 된다.
- SYSCLK 은 MCO MUX를 통해서 MCO pin으로 출력해 오실로스코프로 확인이 가능하다.

#MCO란 MII용 clock source 출력단으로 이더넷 PHY에 사용된다.





#### **Clock Tree**



- 시스템 클럭을 APB1 prescaler을 이용해 최대 36MHz 클럭을 PCLK1에 제공 가능하다.
- 시스템 클럭을 APB2 prescaler을 이용해 최대 72MHz 클럭을 PCLK2에 제공 가능하다.



#### **Clock Tree**



- FCLK(**F**ree running **Cl**oc**k**): Cortex System(CPU)용 Clock
- HCLK(Advanced High Performance Bus Clock): AHB Bus(DMA, Core memory 등 고속 동작 장치)에 사용되는 Clock
- PCLK(Advanced Peripheral Bus Clock):
   APB Bus(ADC, GPIO, UART등 느린 동작 장치)에 사용되는 Clock



#### PLL(Phase-Locked Loop)

### Clock 제어에 사용되는 여러가지 레지스터

#### 8.3.2 Clock configuration register (RCC\_CFGR)

Address offset: 0x04

Reset value: 0x0000 0000

Access: 0 ≤ wait state ≤ 2, word, half-word and byte access

1 or 2 wait states inserted only if the access occurs during a clock source switch.

#### 8.3.12 Clock configuration register2 (RCC\_CFGR2)

Address offset: 0x2C

Reset value: 0x0000 0000

Access: no wait state, word, half-word and byte access

#### 8.3.1 Clock control register (RCC\_CR)

Address offset: 0x00

Reset value: 0x0000 XX83 where X is undefined.

Access: no wait state, word, half-word and byte access

### 예) APB2에서 2로 나누기

#### 8.3.2 Clock configuration register (RCC\_CFGR)

Address offset: 0x04

Reset value: 0x0000 0000

Access: 0 ≤ wait state ≤ 2, word, half-word and byte access

1 or 2 wait states inserted only if the access occurs during a clock source switch.

| MCO[3:0] OTG                          | TGES      |          | PLL     |    |  |
|---------------------------------------|-----------|----------|---------|----|--|
| Reserved Res. PH                      | PRE PLLMU |          |         |    |  |
| rw rw rw rw                           | rw rw rw  | rw rw    | rw      | rw |  |
| 15 14 13 12 11 10 9 8 7 6             | 6 5 4     | 3 2      | 1       | 0  |  |
| ADC PRE[1:0] PPRE2[2:0] PPRE1[2:0] HF | HPRE[3:0] | SWS[1:0] | SW[1:0] |    |  |
| rw rw rw rw rw rw rw rw               | rw rw rw  | r r      | rw      | rw |  |



Bits 13:11 PPRE2[2:0]: APB high-speed prescaler (APB2)

Set and cleared by software to control the division factor of the APB High speed clock (PCLK2).

0xx: HCLK not divided

100: HCLK divided by 2

101: HCLK divided by 4

110: HCLK divided by 8 111: HCLK divided by 16 예시: RCC->CFGR |= (RCC\_CFGR\_PPRE2\_DIV2 | RCC\_CFGR\_PLLSRC\_PREDIV1)



### 현재 보드의 External Clock





100(10진수) → 0x64(16진수) → 01100100(2진수)



- 1. Parallel Communication(병렬 통신)
- 여러 개의 데이터 선을 이용해, 각각의 선에 비트를 하나씩 보내는 방법

- 2. Serial Communication(직렬 통신)
- 하나의 데이터 선을 이용해 비트를 차례로 보내는 방법
- 속도는 느리나, 데이터 선을 연장하기 위한 비용이 적음



Universal Sync/Async Receiver/Transmitter (USART)



- 동기식 통신을 지원하는 UART
- 데이터 동기화를 위해 같은 클럭을 사용함
- 클럭 전송을 위한 별도의 클럭선 필요
- Start bits/ Stop bits가 없고 Data bits를 클럭에 동기화해 전송



Universal Asynchronous Receiver/Transmitter (UART)





- 비동기 통신 프로토콜
- Rx(데이터 수신)와 Tx(데이터 송신) 교차연결
- 비동기 통신이기 때문에 Baud Rate를 일치 시켜야 한다.
- Baud Rate란 초당 얼마나 많은 심볼(의미 있는 데이터 묶음)을 전송할 수 있는가



Universal Asynchronous Receiver/Transmitter



- Start bit : 통신의 시작을 의미하며 1bit 길이 만큼 유지. "이제부터 정해진 약속에 따라 통신을 시작한다" 라는 의미
- Data bit : 8~9 bit의 데이터를 전송. Bit의 개수는 레지스터 설정에 따라 다름
- Parity bit : 에러 검사를 위한 값. 수신 측에서 이 bit를 이용해 에러 검사
- Stop bit : 통신의 종료를 알림. 레지스터에 따라 1, 1.5, 2bit로 설정



Universal Asynchronous Receiver/Transmitter

| 1 |   | 실저 | ∥ 전송 | 하고자 | 하는 | 8-Bit D | 패리티 비트 |   |   |  |
|---|---|----|------|-----|----|---------|--------|---|---|--|
|   | 1 | 0  | 0    | 1   | 0  | 1       | 0      | 1 | 1 |  |

#### 패리티 비트

- <u>데이터 송수신 시 오류로 인해 bit가 1 -> 0 또는 0 -> 1로 바뀌었을 때 확인할 수</u> <u>있는 보호장치</u>
- <u>에러 발생 여부는 확인 가능하나, 오류 수정은 불가</u>
- 수신 측에서 에러 발생 여부 확인 후, 데이터 재요청 가능



#### Universal Asynchronous Receiver/Transmitter



Even parity, Odd Parity 설정에 따라, Parity bit의 값이 다름

- Even Parity: (전송하고자 하는 데이터 + parity bit) 중 1인 bit의 개수가 짝수
- Odd Parity : (전송하고자 하는 데이터 + parity bit) 중 1인 bit의 개수가 홀수
- Even, Odd 설정은 송수신 측이 미리 동기화되어 있어야 함.

## **System Clock Generate**



```
RCC->CFGR |= (uint32 t)RCC CFGR HPRE DIV1;
      RCC->CFGR |= (uint32 t)RCC CFGR PPRE2 DIV1;
      RCC->CFGR |= (uint32 t)RCC CFGR PPRE1 DIV1;
      RCC->CFGR &= (uint32 t)~(RCC CFGR PLLXTPRE | RCC CFGR PLLSRC | RCC CFGR PLLMULL);
      RCC->CFGR |= (uint32_t)(RCC_CFGR_PLLXTPRE_PREDIV1 | RCC_CFGR_PLLSRC_PREDIV1 |
      RCC CFGR PLLMULL1);
      RCC->CFGR2 &= (uint32 t)~(RCC CFGR2 PREDIV2 | RCC CFGR2 PLL2MUL |
      RCC_CFGR2_PREDIV1 | RCC_CFGR2_PREDIV1SRC);
      RCC->CFGR2 |= (uint32 t)(RCC CFGR2 PREDIV2 DIV1 | RCC CFGR2 PLL2MUL1 |
      RCC_CFGR2_PREDIV1SRC_PLL2 | RCC_CFGR2_PREDIV1_DIV1);
      RCC->CR |= RCC_CR_PLL2ON;
      while ((RCC->CR & RCC CR PLL2RDY) == 0)
      RCC->CR |= RCC_CR_PLLON;
      while ((RCC->CR & RCC CR PLLRDY) == 0)
                                                  void RCC Enable(void) {
                                                  //@TODO - 3 RCC Setting
                                                      /*---- RCC Configurat
                                                      /* GPIO RCC Enable */
      RCC->CFGR &= (uint32 t)((uint32 t)~(RCC CFGR
                                                      /* UART Tx, Rx, MCO */
      RCC->CFGR |= (uint32 t)RCC CFGR SW PLL;
                                                      //RCC->APB2ENR |= ??
      /* Wait till PLL is used as system clock sour
                                                      /* USART RCC Enable */
      while ((RCC->CFGR & (uint32 t)RCC CFGR SWS) !
                                                      // RCC->APB2ENR |= ??
                                                  void PortConfiguration(void) {
//@TODO - 2 Set the MCO port for system clock output
                                                  //@TODO - 4 GPIO Configuration
      RCC->CFGR &= ~(uint32 t)RCC CFGR MCO;
                                                      /* Reset Port A CRH */
                                                      // GPIOA->CRH &= ??
                                                      /* Reset Port B CRH */
                                                      // GPIOB->CRH &= ??
                                                      /* MCO Pin Configuration */
                                                      // GPIOA->CRH |= ??
                                                      /* USART Pin Configuration */
                                                      // GPIOA->CRH |= ??
                                                      /* User S1 Button Configuration */
```

// GPIOD->CRH |= ??

#### TODO 부분

- reference 및 datasheet 참고하여 코드 채워 넣기
- · 주소 및 대입 값 정의된 이름으로 입력하 기

```
oid UartInit(void) {
  USART1->CR1 &= ~(uint32_t)(USART_CR1_M | USART_CR1_PCE | USART_CR1_PS | USART_CR1_TE | USART_CR1_RE);
  USART1->CR2 &= ~(uint32 t)(USART CR2 STOP);
  USART1->CR2 &= ~(uint32_t)(USART_CR2_CPHA | USART_CR2_CPOL | USART_CR2_CLKEN);
  USART1->CR3 &= ~(uint32_t)(USART_CR3_CTSE | USART_CR3_RTSE);
  /* Configure the USART Baud Rate -----*,
```

## GPIO 설정





|        | Pins   |         |                   | Т       |                            |                                                  | nitions (continued)  Alternate fund                                          | tions(4)                                     |
|--------|--------|---------|-------------------|---------|----------------------------|--------------------------------------------------|------------------------------------------------------------------------------|----------------------------------------------|
| BGA100 | LQFP64 | LQFP100 | Pin name          | Type(1) | I / O Level <sup>(2)</sup> | Main<br>function <sup>(3)</sup><br>(after reset) | Atternate fund                                                               | Remap                                        |
| J9     | -      | 56      | PD9               | I/O     | FT                         | PD9                                              | -                                                                            | USART3_RX/<br>ETH_MII_RXD0/<br>ETH_RMII_RXD0 |
| Н9     | -      | 57      | PD10              | I/O     | FT                         | PD10                                             | USART3_CK/<br>ETH_MII_RXD1/<br>ETH_RMII_RXD1                                 |                                              |
| G9     | -      | 58      | PD11              | I/O     | FT                         | PD11                                             | -                                                                            | USART3_CTS/<br>ETH_MII_RXD2                  |
| K10    | -      | 59      | PD12              | I/O     | FT                         | PD12                                             | -                                                                            | TIM4_CH1 /<br>USART3_RTS/<br>ETH_MII_RXD3    |
| J10    | -      | 60      | PD13              | I/O     | FT                         | PD13                                             | -                                                                            | TIM4_CH2                                     |
| H10    | -      | 61      | PD14              | I/O     | FT                         | PD14                                             | -                                                                            | TIM4_CH3                                     |
| G10    | -      | 62      | PD15              | I/O     | FT                         | PD15                                             | -                                                                            | TIM4_CH4                                     |
| F10    | 37     | 63      | PC6               | I/O     | FT                         | PC6                                              | I2S2_MCK/                                                                    | TIM3_CH1                                     |
| E10    | 38     | 64      | PC7               | I/O     | FT                         | PC7                                              | I2S3_MCK                                                                     | TIM3_CH2                                     |
| F9     | 39     | 65      | PC8               | I/O     | FT                         | PC8                                              | -                                                                            | TIM3_CH3                                     |
| E9     | 40     | 66      | PC9               | I/O     | FΤ                         | PC9                                              |                                                                              | TIM3_CH4                                     |
| D9     | 41     | 67      | PA8               | I/O     | FT                         | PA8                                              | USART1_CK/OTG_FS_SOF /<br>TIM1_CH1 <sup>(8)</sup> /MCO                       | -                                            |
| C9     | 42     | 68      | PA9               | I/O     | FT                         | PA9                                              | USART1_TX <sup>(7)</sup> / TIM1_CH2 <sup>(7)</sup> /<br>OTG_FS_VBUS          | -                                            |
| D10    | 43     | 69      | PA10              | I/O     | FT                         | PA10                                             | USART1_RX <sup>(7)</sup> /<br>TIM1_CH3 <sup>(7)</sup> /OTG_FS_ID             |                                              |
| C10    | 44     | 70      | PA11              | I/O     | FT                         | PA11                                             | USART1_CTS / CAN1_RX /<br>TIM1_CH4 <sup>(7)</sup> /OTG_FS_DM                 | -                                            |
| B10    | 45     | 71      | PA12              | I/O     | FT                         | PA12                                             | USART1_RTS / OTG_FS_DP /<br>CAN1_TX <sup>(7)</sup> / TIM1_ETR <sup>(7)</sup> | -                                            |
| A10    | 46     | 72      | PA13              | I/O     | FT                         | JTMS-SWDIO                                       | -                                                                            | PA13                                         |
| F8     | -      | 73      |                   |         |                            | Not connect                                      | led                                                                          | -                                            |
| E6     | 47     | 74      | V <sub>SS_2</sub> | S       | -                          | V <sub>SS_2</sub>                                | -                                                                            | -                                            |
| F6     | 48     | 75      | V <sub>DD_2</sub> | S       | -                          | V <sub>DD_2</sub>                                | -                                                                            | -                                            |
| A9     | 49     | 76      | PA14              | 1/0     | FT                         | JTCK-SWCLK                                       | -                                                                            | PA14                                         |

- MCO 및 UART 사용을 위한 PORT/PIN 의
   GPIO 설정이 필요함
- Datasheet의 Table 5. Pin definitions
   (p27~32) 참고
  - MCO 및 UART TX: Alternate function output Push-pull 으로 설정
  - UART RX: Input with pull-up / pulldown 으로 설정

## **Baud rate Example**



#### 27.6.3 Baud rate register (USART\_BRR)

Note: The baud counters stop counting if the TE or RE bits are disabled respectively.

Address offset: 0x08 Reset value: 0x0000

|   | 31                 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20      | 19         | 18 | 17 | 16 |
|---|--------------------|----|----|----|----|----|----|----|----|----|----|---------|------------|----|----|----|
| [ | Reserved           |    |    |    |    |    |    |    |    |    |    |         |            |    |    |    |
|   | 15                 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4       | 3          | 2  | 1  | 0  |
|   | DIV_Mantissa[11:0] |    |    |    |    |    |    |    |    |    |    | DIV_Fra | ction[3:0] |    |    |    |
|   | rw                 | rw | rw | rw | rw | rw | rw | rw | rw | rw | rw | rw      | rw         | rw | rw | rw |

Bits 31:16 Reserved, forced by hardware to 0.

Bits 15:4 DIV\_Mantissa[11:0]: mantissa of USARTDIV

These 12 bits define the mantissa of the USART Divider (USARTDIV)

Bits 3:0 DIV\_Fraction[3:0]: fraction of USARTDIV

These 4 bits define the fraction of the USART Divider (USARTDIV)

### Baud rate 계산 예제 ReferenceManual 에 있음

#### Fractional baud rate generation

The baud rate for the receiver and transmitter (Rx and Tx) are both set to the same value as programmed in the Mantissa and Fraction values of USARTDIV.

Tx/ Rx baud = 
$$\frac{f_{CK}}{(16*USARTDIV)}$$

legend: f<sub>CK</sub> - Input clock to the peripheral (PCLK1 for USART2, 3, 4, 5 or PCLK2 for USART1)

USARTDIV is an unsigned fixed point number that is coded on the USART\_BRR register.

The baud counters are updated with the new value of the Baud registers after a write to USART\_BRR. Hence the Baud rate register value should not be changed during communication.

#### How to derive USARTDIV from USART\_BRR register values

#### Example 1:

If DIV\_Mantissa = 0d27 and DIV\_Fraction = 0d12 (USART\_BRR = 0x1BC), then Mantissa (USARTDIV) = 0d27

Fraction (USARTDIV) = 12/16 = 0d0.75

Therefore USARTDIV = 0d27.75

#### Example 2:

To program USARTDIV = 0d25.62

This leads to:

"0d": decimal을 뜻함

DIV\_Fraction = 16\*0d0.62 = 0d9.92

The nearest real number is 0d10 = 0xA

DIV\_Mantissa = mant<u>issa (0d</u>25.620) = 0d<u>25</u> = 0x19

Then, USART\_BRR = 0x19A nence USARTDIV = 0d25.625

#### Example 3:

To program USARTDIV = 0d50.99

This leads to:

 $DIV_Fraction = 16*0d0.99 = 0d15.84$ 

The nearest real number is 0d16 = 0x10 => overflow of DIV\_frac[3:0] => carry must be added up to the mantissa

DIV\_Mantissa = mantissa (0d50.990 + carry) = 0d51 = 0x33

Then, USART\_BRR = 0x330 hence USARTDIV = 0d51.000

# Clock을 이용한 시리얼 통신





해당 Serial Port를 PC와 연결해 Serial 통신

## Clock을 이용한 시리얼 통신





PC에서 시리얼 통신을 확인할 때 쓰는 프로그램 PC에 없으면 인터넷에서 최신버전 설치하세요

PC 장치 관리자에서 보드와 연결된 Serial Port 확인



Connection type - Serial 선택 후 확인한 Port 입력, Baud rate 입력

Open



## 오실로스코프 아날로그 측정 방법





1번 : 신호를 Analog로 받기 위해 설정

2번: Meas 버튼 눌러 측정 시작

3번 : frequency 모드로 변경

4번 : 화면에 frequency 출력

5번: Auto scale 버튼 누르면 그래프가 깔끔해짐

# 오실로스코프 아날로그 측정 방법





주의! 보드에 GND 붙이다 근접한 VCC와 합선시 보드 망가질 수 있음

# 실험 주의사항



레퍼런스 매뉴얼



## 실험 주의사항



- 실험 장비들을 연결 및 분리할 때 반드시 모든 전원을 끄고 연결해주세요.
- 장비사용시 충격이 가해지지 않도록 주의해주세요.
- 자리는 항상 깔끔하게 유지하고 반드시 정리 후 퇴실해주세요.
- 실험 소스 코드와 프로젝트 폴더는 백업 후 반드시 삭제해주세요.
- 장비 관리, 뒷정리가 제대로 되지 않을 경우 해당 조에게 감점이 주어집니다.
- 동작 중 케이블 절대 뽑지말것
- 보드는 전원으로 USBPort나 어댑터(5V,1A)를 사용할것 (5V 5A 어댑터(비슷하게 생김) 와 혼동하지 말 것, 사용시 보드가 타버림 -> 감점)
- 디버깅 모드 중에 보드 전원을 끄거나 연결 케이블을 분리하지 말 것!!!
- ->지켜지지 않을 시 해당 조 감점

## 실험미션



#### 미션!별도 미션지 참고

### 실험 검사

오늘 검사 받을 수 있는 조는 오늘 받고 못 받는 조는 따로 미션 수행 후 다음 주 수업 시작할 때 검사

이번 주 실험 결과 보고서 및 소스 코드 및 실험 동작 영상

- A. 이론부터 실습까지 전반적인 내용을 포함하도록 작성 (실험 과정 사진 찍으시면 좋아요)
- B. 다음 실험시간 전까지 Email(chrismail@naver.com) 제출
- C. 소스 코드는 직접 작성 및 수정한 파일만 제출

나가실 때, 만드신 코드 및 프로젝트 폴더는 모두 백업하시고 삭제해주세요. 다른 분반 파일은 만지지 마시고 조교에게 알려주세요. 자리 정리정돈 안 되어 있으면 <mark>감점</mark>합니다!!!